<template>
  <a-spin :spinning="confirmLoading">
    <a-form ref="formRef" class="antd-modal-form" :labelCol="labelCol" :wrapperCol="wrapperCol">
      <a-row>
        <a-divider type="vertical" class="antd-modal-divider" />
        <h4 class="hClass">基本信息</h4>
      </a-row>
      <a-row>
        <a-col :span="8">
          <a-form-item label="器具名称" v-bind="validateInfos.uteName">
            <a-input v-model:value="formData.uteName" :disabled="disabled"></a-input>
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="器具自编号" v-bind="validateInfos.uteNumber">
            <a-input v-model:value="formData.uteNumber" :disabled="disabled"></a-input>
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="出厂编号" v-bind="validateInfos.manuNumber">
            <a-input v-model:value="formData.manuNumber" :disabled="disabled"></a-input>
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="型号/规格/等级" v-bind="validateInfos.specification">
            <a-input v-model:value="formData.specification" :disabled="disabled"></a-input>
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="测量范围" v-bind="validateInfos.usableRange">
            <a-input v-model:value="formData.usableRange" :disabled="disabled"></a-input>
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="用途" v-bind="validateInfos.purpose">
            <a-input v-model:value="formData.purpose" :disabled="disabled"></a-input>
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="设备分类(A/B/C/D)" v-bind="validateInfos.sort">
            <j-dict-select-tag v-model:value="formData.sort" dictCode="type" :disabled="disabled" />
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="责任人" v-bind="validateInfos.personResponsible">
            <JSelectUser v-model:value="formData.personResponsible" :disabled="disabled" row-key="id"
              :showButton="false" />
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="存放位置" v-bind="validateInfos.storageLocation">
            <a-input v-model:value="formData.storageLocation" :disabled="disabled"></a-input>
          </a-form-item>
        </a-col>
      </a-row>
      <a-row>
        <a-divider type="vertical" class="antd-modal-divider" />
        <h4 class="hClass">器具检定</h4>
      </a-row>
      <a-row>
        <a-col :span="8">
          <a-form-item label="检定参数/送检项" v-bind="validateInfos.heckItem">
            <a-input v-model:value="formData.heckItem" :disabled="disabled"></a-input>
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="溯源方式" v-bind="validateInfos.traceabilityMethod">
            <j-dict-select-tag v-model:value="formData.traceabilityMethod" dictCode="last_type" :disabled="disabled" />
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="是否现场检定" v-bind="validateInfos.fieldInspect">
            <j-dict-select-tag v-model:value="formData.fieldInspect" dictCode="utesil_check" :disabled="disabled" />
          </a-form-item>
        </a-col>
      </a-row>
      <a-row>
        <a-divider type="vertical" class="antd-modal-divider" />
        <h4 class="hClass">检定信息</h4>
      </a-row>
      <a-row>
        <a-col :span="8">
          <a-form-item label="检定周期/(月)" v-bind="validateInfos.inspectCycle">
            <!-- <a-input-number v-model:value="formData.inspectCycle" style="width: 100%;" :disabled="disabled" /> -->
            <a-input-number v-model:value="formData.inspectCycle" style="width: 100%" :disabled="disabled"  />
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="上次检定日期" v-bind="validateInfos.lastInspectDate">
            <a-date-picker v-model:value="formData.lastInspectDate" value-format="YYYY-MM-DD" style="width: 100%"
              :disabled="disabled" />
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="有效截止日期" v-bind="validateInfos.expirationDate">
            <a-date-picker v-model:value="formData.expirationDate" value-format="YYYY-MM-DD" style="width: 100%"
              :disabled="disabled" />
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="计划送检日期" v-bind="validateInfos.planInspectDate">
            <a-date-picker v-model:value="formData.planInspectDate" value-format="YYYY-MM-DD" style="width: 100%"
              :disabled="disabled" />
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="确认结果" v-bind="validateInfos.confirmResult">
            <j-dict-select-tag v-model:value="formData.confirmResult" dict-code="ute_result" :disabled="disabled" />
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="确认人" v-bind="validateInfos.confirmPerson">
            <a-input v-model:value="formData.confirmPerson" :disabled="disabled"></a-input>
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="备注" v-bind="validateInfos.remark">
            <a-textarea v-model:value="formData.remark" rows="4" :disabled="disabled"
              style="width: 840px; border-radius: 4px 4px 4px 4px;  opacity: 1;  border: 0.5px solid #DDDDDD;" />
          </a-form-item>
        </a-col>
        <a-col :span="8">
          <a-form-item label="器具照片" v-bind="validateInfos.utePicture">
            <j-image-upload v-model:value="formData.utePicture" :disabled="disabled"></j-image-upload>
          </a-form-item>
        </a-col>
        <!-- <a-col :span="8">
          <a-form-item label="规程文件" v-bind="validateInfos.instructions">
            <j-upload v-model:value="formData.instructions" :disabled="disabled">
            </j-upload>
          </a-form-item>
        </a-col> -->
        <a-col :span="8">
          <a-form-item label="规程文件" v-bind="validateInfos.instructions">
            <MyUpload v-model:value="formData.instructions" :disabled="disabled"></MyUpload>
          </a-form-item>
        </a-col>
      
      </a-row>

      <!-- 插入表格 -->
      <div v-show="disabled">
        <a-tabs style="margin-bottom: 3px;">
          <a-tab-pane tab="器具校验记录">
            <div style="margin-bottom: 3px;">
              <a-row type="flex" style="margin-bottom: 3px;">
                <!-- <a-col :span="3" style="text-align: center;">委托编号</a-col> -->
                <a-col :span="3" style="text-align: center;">检定时间</a-col>
                <a-col :span="3" style="text-align: center;">有效日期</a-col>
                <a-col :span="3" style="text-align: center;">溯源方式</a-col>
                <a-col :span="3" style="text-align: center;">溯源单位</a-col>
                <a-col :span="3" style="text-align: center;">责任人</a-col>

                <a-col :span="3" style="text-align: center;">检测证书</a-col>
                <!-- <a-col :span="3" style="text-align: center;">费用</a-col> -->
              </a-row>
              <!-- 下面是遍历放入表数据 -->
              <a-row type="flex" style="margin-bottom: 3px;height: 30px;" gutter="1px"
                v-for="( check, index ) in  checkList " :key="index">
                <a-col :span="2" style="display: none">
                  <a-form-item>
                    <a-input placeholder="id" v-model:value="check.id" />
                  </a-form-item>
                </a-col>
                <!-- <a-col :span="3">
                  <a-form-item>
                    <a-input v-model:value="check.checkRef" style="width: 130px;" :disabled="true" />
                  </a-form-item>
                </a-col> -->
                <a-col :span="3">
                  <a-form-item>
                    <a-date-picker valueFormat="YYYY-MM-DD" v-model:value="check.lastDate" style="max-width: 130px;"
                      :disabled="disabled" />
                  </a-form-item>
                </a-col>
                <a-col :span="3">
                  <a-form-item>
                    <a-date-picker valueFormat="YYYY-MM-DD" v-model:value="check.indate" style="max-width: 130px;"
                      :disabled="disabled" />
                  </a-form-item>
                </a-col>
                <a-col :span="3">
                  <a-form-item>
                    <a-input v-model:value="check.lastType" style="width: 130px;" :disabled="disabled" />
                  </a-form-item>
                </a-col>
                <a-col :span="3">
                  <a-form-item>
                    <a-input v-model:value="check.lastFirm" style="width: 130px;" :disabled="disabled" />
                  </a-form-item>
                </a-col>
                <a-col :span="3">
                  <a-form-item>
                    <a-input v-model:value="check.driName" style="width: 130px;" :disabled="disabled" />
                  </a-form-item>
                </a-col>

                <a-col :span="3">
                  <a-form-item>
                    <a-input v-model:value="check.certificate" style="width: 130px;" :disabled="disabled" />
                  </a-form-item>
                </a-col>
                <!-- <a-col :span="3">
                  <a-form-item>
                    <a-input v-model:value="check.fee" style="width: 130px;" :disabled="disabled" />
                  </a-form-item>
                </a-col> -->
              </a-row>
            </div>
          </a-tab-pane>
        </a-tabs>
      </div>
    </a-form>
  </a-spin>
</template>

<script lang="ts" setup>
import { ref, reactive, defineExpose, nextTick, defineProps, computed } from 'vue';
// import { defHttp } from '/@/utils/http/axios';
import { useMessage } from '/@/hooks/web/useMessage';
import JDictSelectTag from '/@/components/Form/src/jeecg/components/JDictSelectTag.vue';//下拉框需导入的支持
import JUpload from '/@/components/Form/src/jeecg/components/JUpload/JUpload.vue';
import JImageUpload from '/@/components/Form/src/jeecg/components/JImageUpload.vue';
import { JSelectUser } from '/@/components/Form';
import { getValueType } from '/@/utils';
import { saveOrUpdate } from '../LabUtensil.api';
import { Form } from 'ant-design-vue';
import { queryBy } from '../../utensil_checkList/LabUtensilChecklist.api';
import MyUpload from './MyUpload.vue';


const props = defineProps({
  formDisabled: { type: Boolean, default: false },
  formData: { type: Object, default: () => { } },
  formBpm: { type: Boolean, default: true }
});
const formRef = ref();
const useForm = Form.useForm;
const emit = defineEmits(['register', 'ok']);
const formData = reactive<Record<string, any>>({
  id: '',
  uteName: '',
  uteNumber: '',
  manuNumber: '',
  specification: '',
  usableRange: '',
  purpose: '',
  sort: '',
  personResponsible: '',
  storageLocation: '',
  heckItem: '',
  traceabilityMethod: '',
  fieldInspect: '',
  inspectCycle: undefined,
  lastInspectDate: '',
  expirationDate: '',
  planInspectDate: '',
  confirmResult: '',
  confirmPerson: '',
  remark: '',
  utePicture: '',
  instructions: '',
  deviceId: '',
});
const { createMessage } = useMessage();
const labelCol = ref<any>({ xs: { span: 24 }, sm: { span: 5 } });
const wrapperCol = ref<any>({ xs: { span: 24 }, sm: { span: 16 } });
const confirmLoading = ref<boolean>(false);
//表单验证
const validatorRules = {
  personResponsible: [{ required: true, message: '请填写责任人!' },],
  manuNumber: [{ required: true, message: '请填写出厂编号!' },],
};
const { resetFields, validate, validateInfos } = useForm(formData, validatorRules, { immediate: true });

// 表单禁用
const disabled = computed(() => {
  if (props.formBpm === true) {
    if (props.formData.disabled === false) {
      return false;
    } else {
      return true;
    }
  }
  return props.formDisabled;
});



/**
 * 新增
 */
function add() {
  edit({});
}

/**
 * 编辑
 */
const checkList = ref([])
const fileList=ref([]);
async function edit(record) {
  nextTick(() => {
    resetFields();
    if (record.record.instructions!==null) {
      fileList.value=record.record.instructions.split(",");
    }
   
    //赋值
    Object.assign(formData, record.record);
  });
  if (record.dis) {
    checkList.value = await queryBy(record.record.manuNumber);
  }
}

/**
 * 提交数据
 */
async function submitForm() {
  // 触发表单验证
  await validate();
  confirmLoading.value = true;
  const isUpdate = ref<boolean>(false);
  //时间格式化
  let model = formData;
  if (model.id) {
    isUpdate.value = true;
  }
  //循环数据
  for (let data in model) {
    //如果该数据是数组并且是字符串类型
    if (model[data] instanceof Array) {
      let valueType = getValueType(formRef.value.getProps, data);
      //如果是字符串类型的需要变成以逗号分割的字符串
      if (valueType === 'string') {
        model[data] = model[data].join(',');
      }
    }
  }

  await saveOrUpdate(model, isUpdate.value)
    .then((res) => {
      if (res.success) {
        createMessage.success(res.message);
        emit('ok');
      } else {
        createMessage.warning(res.message);
      }
    })
    .finally(() => {
      confirmLoading.value = false;
    });
}


defineExpose({
  add,
  edit,
  submitForm,
});
</script>

<style lang="less" scoped>
.antd-modal-form {
  min-height: 500px !important;
  overflow-y: auto;
  padding: 24px 24px 24px 24px;
}


//标题:基本信息 的格式
.antd-modal-divider {
  width: 2px;
  height: 16px;
  background: #009688;
  border-radius: 0px 0px 0px 0px;
  opacity: 1;
}

.hClass {
  width: 60px;
  height: 20px;
  font-size: 14px;
  font-family: Microsoft YaHei-Regular, Microsoft YaHei;
  font-weight: 550;
  color: #009688;
  line-height: 14px;
}

.ant-form-item-label {
  width: 60px;
  height: 20px;
  font-size: 14px;
  font-family: Microsoft YaHei-Regular, Microsoft YaHei;
  font-weight: 400;
  color: #727272;
  line-height: 20px;
}

// .ant-input {
//   width: 200px;
//   height: 32px;
//   border-radius: 4px 4px 4px 4px;
//   opacity: 1;
//   border: 1px solid #DDDDDD;
// }

.ant-picker {
  width: 200px !important;
  height: 32px;
  border-radius: 4px 4px 4px 4px;
  opacity: 1;
  border: 1px solid #DDDDDD;
}


:deep(.ant-form-item-control-input) {
  width: 200px !important;
}

:deep(.ant-col-sm-5) {
  display: block;
  flex: 0 0 38.83333333%;
  max-width: 38.83333333%;
}
</style>
